import wxValidate from 'wechat-validate'
Page({
  behaviors: [wxValidate],
  data: {
    dateLayerVisible: false,
    houseLayerVisible: false,
    houseList: [],
    currentDate: Date.now(),
    maxDate: Date.now() + 1000 * 3600 * 24 * 3, // 最大时间
    "houseInfo": "",
    // 准备的表单数据
    "houseId":"",
    "name": "",
    "gender": 1,
    "mobile":"",
    "visitDate":""
  },
  rules: {
    name: [
      {required: true, message: '访客姓名不能为空!'},
      {pattern: /[\u4e00-\u9fa5]{2,5}/, message: '访客姓名只能为中文!'},
    ],
    mobile: [
      {required: true, message: '访客手机号不能为空!'},
      {pattern: /^1[3-8]\d{9}$/, message: '请填写正确的手机号码!'},
    ],
    houseId: [
      {required: true, message: '请选择到访的房屋!'}
    ],
    visitDate: [
      {required: true, message: '请选择到访的日期!'}
    ],
  },
  onLoad(){
    this.getHouseList()
  },
  // 获取到我的房屋信息
  async getHouseList(){
    let houseList = await wx.http.get('/room')
    // console.log(houseList);
    houseList= houseList.map(item =>({
      name: item.point+ item.building + item.room,
      id:item.id
    }))
    this.setData({ houseList })
  },
  // 选择房屋
    selectHouse({ detail }){
      this.setData({ 
        houseId: detail.id, 
        houseInfo: detail.name})
    },
  // 选择了日期
  selectDateInfo(event){
    this.setData({
      visitDate: wx.utils.dataFormat(event.detail),
      dateLayerVisible: false
    })
  },
  openHouseLayer() {
    this.setData({ houseLayerVisible: true })
  },
  closeHouseLayer() {
    this.setData({ houseLayerVisible: false })
  },
  openDateLayer() {
    this.setData({ dateLayerVisible: true })
  },
  closeDateLayer() {
    this.setData({ dateLayerVisible: false })
  },
  // 表单数据提交
  async goPassport() {
    const isPass= this.validate()
    if(!isPass) return
    const {name, visitDate, mobile, gender, houseId} = this.data
     let res  = await wx.http.post('/visitor',{
      name,visitDate,mobile, gender, houseId
    })
    // 提示
    wx.utils.toast('操作成功')
    // 跳转页面
    setTimeout(()=>{
      wx.reLaunch({
        url: '/visitor_pkg/pages/passport/index?id='+ res.id,
      })
    },300)
 
  },
})
